<?php
/**
 * @title 2841. 几乎唯一子数组的最大和
 * @author start2004
 */

// ini_set("memory_limit", "128M");

// class Solution {
//
//     function find() {
//
//     }
// }

class Solution {

    /**
     * @param Integer[] $nums
     * @param Integer $m
     * @param Integer $k
     * @return Integer
     */
    function maxSum($nums, $m, $k) {
        /**
         * @since 2024-05-22 返回 nums 中长度为 k 的 几乎唯一 子数组的 最大和
         * @since 2024-05-22 滑动窗口，元素k个
         * @since 2024-05-22 哈希记录窗口内每个元素的数量
         */
        $result = 0;
        $cntArray = [];
        $sum = 0;
        for($right=0; $right<$k; $right++){
            $sum += $nums[$right];
            $cntArray[$nums[$right]] = ($cntArray[$nums[$right]] ?? 0) + 1;
        }
        if(count($cntArray) >= $m){
            $result = $sum;
        } else {}

        /**
         * @since 2024-05-22 移动窗口
         */
        for($left=0; $right<count($nums); $left++, $right++){
            $sum = $sum - $nums[$left] + $nums[$right];
            if($cntArray[$nums[$left]] == 1){
                unset($cntArray[$nums[$left]]);
            } else {
                $cntArray[$nums[$left]]--;
            }
            $cntArray[$nums[$right]] = ($cntArray[$nums[$right]] ?? 0) + 1;

            /**
             * @since 2024-05-22 更新最大和
             */
            if(count($cntArray) >= $m){
                $result = max($result, $sum);
            } else {}
        }

        /**
         * @return
         */
        return $result;
    }
}


/**
 * @url http://127.0.0.1/leetcode/202405/2024.05.22_2.php
 */
$datas = [

];

include_once dirname(__DIR__) . DIRECTORY_SEPARATOR ."xhprof.php";
$xhprof = new Xhprof();
foreach ($datas as $data){
    /**
     * @since 2024-01-15 超时和错误案例参数
     */
    // $data = $xhprof->FormatArgs("/tmp/leetcode/xxx-xxx.txt");

    // $data[0] = $xhprof->listNode($data[0]);
    // $data[0] = $xhprof->tree($data[0]);
    echo $xhprof->DumpArgs($data);
    echo "\n<hr>\n";

    $obj = new Solution();
    $result = $obj->(...$data);
    echo $xhprof->DumpArgs([$result]);
    var_dump($result);

    echo "\n<hr>". str_repeat("<br>", 2) . str_repeat(PHP_EOL, 5);
}

// foreach ($datas as $data){
//     $obj = new $data[0][0](...$data[1][0]);
//
//     for ($i=1; $i<count($data[0]); $i++){
//         $func = $data[0][$i];
//         $param = $data[1][$i];
//         $result = $obj->$func(...$param);
//
//         echo $data[0][$i] ."(\"". implode(",", $data[1][$i]) ."\") ";
//             if($result === true){
//                 echo "True";
//             } elseif($result === false) {
//                 echo "False";
//             } elseif($result === null) {
//                 echo "Null";
//             } elseif(is_array($result)) {
//                 var_dump($result);
//             } else {
//                 echo $result;
//             }
//         echo PHP_EOL;
//     }
//
//     echo str_repeat(PHP_EOL, 3);
// }
$xhprof->end();
